home *** CD-ROM | disk | FTP | other *** search
/ SGI Developer Toolbox 6.1 / SGI Developer Toolbox 6.1 - Disc 4.iso / public / fax / src / util / StackBuffer.h < prev    next >
C/C++ Source or Header  |  1994-08-01  |  3KB  |  68 lines

  1. /*    $Header: /usr/people/sam/fax/util/RCS/StackBuffer.h,v 1.4 1994/02/28 14:23:57 sam Rel $ */
  2. /*
  3.  * Copyright (c) 1990, 1991, 1992, 1993, 1994 Sam Leffler
  4.  * Copyright (c) 1991, 1992, 1993, 1994 Silicon Graphics, Inc.
  5.  *
  6.  * Permission to use, copy, modify, distribute, and sell this software and 
  7.  * its documentation for any purpose is hereby granted without fee, provided
  8.  * that (i) the above copyright notices and this permission notice appear in
  9.  * all copies of the software and related documentation, and (ii) the names of
  10.  * Sam Leffler and Silicon Graphics may not be used in any advertising or
  11.  * publicity relating to the software without the specific, prior written
  12.  * permission of Sam Leffler and Silicon Graphics.
  13.  * 
  14.  * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND, 
  15.  * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY 
  16.  * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  
  17.  * 
  18.  * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR
  19.  * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
  20.  * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  21.  * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF 
  22.  * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 
  23.  * OF THIS SOFTWARE.
  24.  */
  25. #ifndef _StackBuffer_
  26. #define    _StackBuffer_
  27.  
  28. #include "Types.h"
  29.  
  30. // A growable buffer of characters, designed to be used on the cpu stack.
  31. // It contains an internal buffer, and avoids allocating memory from
  32. // freestore, unless the buffer is insufficient to the task at hand.
  33.  
  34. class fxStackBuffer {
  35. public:
  36.     fxStackBuffer(u_int amountToGrowBy = 0);
  37.     fxStackBuffer(const fxStackBuffer& sb);
  38.     ~fxStackBuffer();
  39.  
  40.     void put(char c);            // Put the character "c" into the buffer
  41.     void put(char const* c, u_int len);    // Put bunch of bytes in the buffer
  42.     void put(char const* c);
  43.     void set(char c);            // Stick in char w/o extending length
  44.     void reset();            // Reset buffer to empty
  45.     u_int getLength() const;        // Return number of bytes in buffer
  46.  
  47.     // NB: the buffer is *NOT* null terminated, unless you put one there.
  48.     operator char*();            // Return base of buffer
  49. protected:
  50.     char    buf[1000];
  51.     char*    next;
  52.     char*    end;
  53.     char*    base;
  54.     u_int    amountToGrowBy;
  55.  
  56.     void addc(char c);            // make room & add a char to the buffer
  57.     void grow(u_int amount);        // make more room in the buffer
  58. };
  59.  
  60. inline void fxStackBuffer::put(char c)
  61.     { if (next < end) *next++ = c; else addc(c); }
  62. inline void fxStackBuffer::put(char const* c)    { put(c, strlen(c)); }
  63. inline void fxStackBuffer::set(char c)        { put(c); next--; }
  64. inline void fxStackBuffer::reset()        { next = base; }
  65. inline fxStackBuffer::operator char*()        { return base; }
  66. inline u_int fxStackBuffer::getLength() const    { return next - base; }
  67. #endif /* _StackBuffer_ */
  68.